<template>
  <div class="user-wrapper">
    <span class="action">
      <a-icon type="question-circle-o"></a-icon>
    </span>
    <header-notice class="action"/>
    <a-dropdown>
      <span class="action ant-dropdown-link user-dropdown-menu">
        <a-avatar class="avatar" size="small" :src="avatar()"/>
        <span>{{ nickname() }}</span>
      </span>
      <a-menu slot="overlay" class="user-dropdown-menu-wrapper">
        <a-menu-item key="0" disabled>
          <router-link :to="{ name: 'center' }">
            <a-icon type="user"/>
            <span>个人中心</span>
          </router-link>
        </a-menu-item>

        <a-menu-item key="1" disabled>
          <router-link :to="{ name: 'settings' }">
            <a-icon type="setting"/>
            <span>账户设置</span>
          </router-link>
        </a-menu-item>

        <a-menu-divider/>

        <a-menu-item key="2">
          <a href="javascript:;" @click="handleLogout">
            <a-icon type="logout"/>
            <span>退出登录</span>
          </a>
        </a-menu-item>
      </a-menu>
    </a-dropdown>
  </div>
</template>

<script>
  import HeaderNotice from './HeaderNotice'
  import { mapActions, mapGetters } from 'vuex'

  export default {
    name: 'UserMenu',

    components: {
      HeaderNotice
    },

    methods: {
      ...mapActions([
        'logout'
      ]),

      ...mapGetters([
        'nickname',
        'avatar'
      ]),

      handleLogout () {
        const that = this

        this.$confirm({
          title: '提示',
          content: '真的要注销登录吗 ?',
          onOk () {
            return that.logout()
              .then(() => {
                window.location.reload()
              })
              .catch(err => {
                that.$message.error({
                  title: '错误',
                  description: err.message
                })
              })
          },
          onCancel () {
          }
        })
      }
    }
  }
</script>
